<template>
  <div>
    <el-checkbox-group v-model="roleIds">
      <el-checkbox
        v-for="item in list"
        :key="item.id"
        :label="item.id"
      >
        {{ item.name }}
      </el-checkbox>
    </el-checkbox-group>

    <div style="margin-top: 20px; text-align: right">
      <el-button type="primary" @click="hSubmit">确定</el-button>
      <el-button @click="$emit('success')">取消</el-button>
    </div>
  </div>
</template>
<script>
import { assignRoles, getRoles } from '@/api/settings'
import { getUserInfo } from '@/api/user'
export default {
  props: {
    curId: {
      type: String,
      required: true
    }
  },
  data() {
    return {
      roleIds: [],
      list: []
    }
  },
  created() {
    this.loadRoles()
  },
  methods: {
    async hSubmit() {
      await assignRoles({ id: this.curId, roleIds: this.roleIds })
      this.$emit('success')
    },
    async loadRoles() {
      const res = await getRoles({ page: 1, pagesize: 1000 })
      const info = await getUserInfo(this.curId)
      this.roleIds = info.data.roleIds
      this.list = res.data.rows
    }
  }
}
</script>

